# SpyGlass Receiver

#### • Clk Gating

- InferLatch: Latch inferred
   always @(ClkIn or Enable) begin
   if (!ClkIn) begin
   LatchEn <= Enable;
   End</li>
- → Ignore this error as we already want this latch

## • Esc\_Deserializer

- Sequential and combinational parts of an FSM description should be separated
  - ➤ Combinational and sequential parts of an FSM bit\_count described in the same always block.

```
if (bit_count==7) begin
   RxEscData <= {SerBit, shift reg[6:0]};</pre>
```

→ Solution:

```
if (&(bit_count[2:0]) ) begin
   RxEscData <= {SerBit, shift_reg[6:0]};</pre>
```

- ImproperRangeIndex-ML
  - ➤ Index 'bit\_count' of width '4' is larger than the width '3' required for the max value '7' of the signal 'shift\_reg' shift\_reg[bit\_count] <= SerBit;
- → Solution:

```
reg [2:0] bit count; // 3-bit counter (0 to 7)
```

- Clock\_check04: Flags usage of both edges in a design
  - ➤ Recommended edge (positive) of clock not used always @(negedge RxClkEsc or negedge RstN)
- → Ignore this warning as we already need to check at the negedge.

#### • Sequence Detector

- Unequal length operands in bit wise logical/arithmetic/ternary/relational operator
  - For operator (^), left expression: 'symbol\_count' width 4 should match right expression: 'saved\_five' width 3.

```
if (&(~(symbol_count ^ saved_five)))
```

→ Solution: reg [3:0] saved five;

### • Word Clock Gen

- Design has a clock driving it on both edges always @(posedge SymClk or negedge RST)

always @(negedge SymClk or negedge RST)

→ Ignore that error as we need to count the both edges in the design.

#### SlaveFSM

- Signal may be multiply assigned (beside initialization) in the same scope
  - ➤ Signal 'nextState' is being assigned multiple times in the same always block.

```
FORCE_RX: begin

if (CtrlDecoderOut==2'b00) nextState= RX_STOP;
else nextState = FORCE_RX;
end

default: nextState = RX_STOP;
endcase

if (ForceTxStopmode) nextState = TX_STOP;
if (ForceRxmode) nextState = FORCE_RX;
end
```

→ Solution:

- NoFeedThrus-ML: Block should not contain feed-throughs
  - There is feed-through from input 'HsClk' to output 'RxWordClkHs'

assign RxWordClkHS = HsCLK;

→ Ignore this warning and the same warnings from the other signals.